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This listing of claims will replace all prior versions, and listings, of claims in the application. 
Listing of Claims: 

1 . (Currently Amended) A method of recovering an application using a timeline-based 
computing environment, the method comprising the steps of: 

periodically saving data items of the application for recovery, wherein the saved 
data items allow the recovery of the application at a point in time when the items were 
saved; 

searching a time-based archive of the saved data items; 

designating a point in time from which to recover the application; and 

recovering the application using the data items saved at the designated point in 

timei_T 

wherein periodically saving data items further comprises the steps of: 

making a first determination of whether the application is of a type that saves a 
consistent working file without receiving a quit request; 

observing the application and capturing the consistent working file if the first 
determination is true; 

if the first determination is not true, making a second determination of whether the 
application is of a type that saves a consistent recovery file without receiving a quit request 
but must receive a quite request in order to save a consistent working file; 

if the second determination is true, observing the application for any recovery file that 
is saved and capturing the saved recovery file; 

capturing a mapping between the captured recovery file and the consistent working 

file; 

if the second determination is not true, making a third determination of whether the 
application must receive a quit request before saving a consistent working file; 

if the third determination is true, creating a clone of the application; 

sending a quit command to the clone of the application to initiate a save file 
command; and 

capturing any saved files responsive to the save file command. 
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2. (Original) The method according to claim 1 further comprising the step of saving 
contextual information relevant to the point in time when the data items are saved. 

3. (Original) The method according to claim 1 further comprising the step of 
generating a fork of the recovered application at the designated point for usage. 

4. (Original) The method according to claim 3 wherein the generated fork is an 
alternative timeline reflecting new usage of the recovered application. 

5. (Cancelled) 

6. (Cancelled) 

7. (Cancelled) 

8. (Currently Amended) The method according to claim 1 wherein the saving stop 
further comprises the steps of: 

if the third determination is not true, making a fourth determination of determining 
whether there is sufficient space to capture a machine state; 

if the fourth determination is true, r unning a virtual machine when there is sufficient 
space to capture the machine state; 

executing the application in the virtual machine; and 

capturing the state of the virtual machine at the point in time. 

9. (Withdrawn) The method according to claim 1 wherein the searching step comprises 
the steps of: 

indexing metadata for each saved data item; and 

generating a list of data items according to a match between the indexed metadata 
and a user selected variable. 



Page 4 of 13 



DOCKET NO.: MSFT-504 1/307240.01 PATENT 

Application No.: 10/808,099 

Office Action Dated: March 16, 2007 

10. (Withdrawn) The method according to claim 9 wherein the indexing step further 
comprises the step of generating the metadata according to a user action or an automatic 
algorithm that catalogues the saved data items. 

1 1 . (Withdrawn) The method according to claim 1 wherein the searching step comprises 
the steps of: 

scrolling on a timeline indicating different points in time; and 

changing a graphical representation of the application according to the scrolling 

step. 

12. (Withdrawn) The method according to claim 1 1 wherein the scrolling provides an 
indication of degree, volume, or type of the saved data items. 

1 3 . (Withdrawn) The method according to claim 1 wherein the application is a 
communication client having a plurality of messages, the method further comprising the steps 
of: 

saving an index data to indicate whether a message in the communication client is 
spam; and 

generating a list of messages according to a match between the plurality of 
messages that are not indicated as spam and a user selected search variable. 

14. (Withdrawn) The method according to claim 1 wherein the application is a 
communication client having a plurality of messages, the method further comprising the steps 
of: 

marking an index data to indicate whether a message in the communication client 
is spam; 

purging all messages marked as spam prior to the step of periodically saving data 
items of the application for recovery. 

15. (Original) The method according to claim 1 further comprising the steps of: 

copying data from the application recovered at the designated point in time; 
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returning to a current point in time; and 

pasting the copied data in the application in the current point in time. 

16. (Currently Amended) A computer-readable medium having thereon computer- 
executable instructions for recovering an application using a timeline-based computing 
environment, the 

instructions for performing steps comprising: 

periodically saving data items of the application for recovery, wherein the saved 
data items allow the recovery of the application at a point in time when the items were 
saved; 

searching a time-based archive of the saved data items; 

designating a point in time from which to recover the application; and 

recovering the application using the data items saved at the designated point in 

time^T 

wherein periodically saving data items further comprises the steps of: 

making a first determination of whether the application is of a type that saves a 
consistent working file without receiving a quit request; 

observing the application and capturing the consistent working file if the first 
determination is true; 

if the first determination is not true, making a second determination of whether the 
application is of a type that saves a consistent recovery file without receiving a quit request 
but must receive a quite request in order to save a consistent working file; 

if the second determination is true, observing the application for any recovery file that 
is saved and capturing the saved recovery file; 

capturing a mapping between the captured recovery file and the consistent working 

file; 

if the second determination is not true, making a third determination of whether the 
application must receive a quit request before saving a consistent working file; 

if the third determination is true, creating a clone of the application; 

sending a quit command to the clone of the application to initiate a save file 
command; and 
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ca pturing any saved files responsive to the save file command. 

17. (Original) The medium according to claim 16 further comprising computer- 
executable instructions for saving contextual information relevant to the point in time when 
the data items are saved. 

18. (Original) The medium according to claim 16 further comprising computer- 
executable instructions for generating a fork of the recovered application at the designated 
point for usage. 

19. (Original) The medium according to claim 18 wherein the generated fork is an 
alternative timeline reflecting new usage of the recovered application. 

20. (Cancelled) 

21. (Cancelled) 

22. (Cancelled) 

23. (Currently Amended) The medium according to claim 16 wherein the computer- 
executable instructions for periodically saving data items further comprise computer- 
executable instructions for: 

if the third determination is not true, making a fourth determination of determining 
whether there is sufficient space to capture a machine state; 

if the fourth determination is true, r unning a virtual machine when there is sufficient 
space to capture the machine state; 

executing the application in the virtual machine; and 

capturing the state of the virtual machine at the point in time. 

24. (Withdrawn) The medium according to claim 16 wherein the computer-executable 

instructions for searching a time-based archive further comprising executable instructions for: 
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indexing metadata for each saved data item; and 

generating a list of data items according to a match between the indexed metadata 
and a user selected variable. 

25. (Withdrawn) The medium according to claim 24 wherein the computer-executable 
instructions for indexing metadata comprising executable instructions for generating the 
metadata according to a user action or an automatic algorithm that catalogues the saved data 
items. 

26. (Withdrawn) The medium according to claim 16 wherein the computer-executable 
instructions for searching a time-based archive further comprising executable instructions for: 

scrolling on a timeline indicating different points in time; and 

changing a graphical representation of the application according the scrolling 

step. 

27. (Withdrawn) The medium according to claim 26 wherein the computer-executable 
instructions for scrolling on a timeline provides an indication of degree, volume, or type of 
the saved data items. 

28. (Withdrawn) The medium according to claim 16 wherein the application is a 
communication client having a plurality of messages, the medium further comprises 
computer-executable instructions for: 

saving an index data to indicate whether a message in the communication client is 
spam; and 

generating a list of messages according to a match between the plurality of 
messages that are not indicated as spam and a user selected search variable. 

29. (Withdrawn) The medium according to claim 16 wherein the application is a 

communication client having a plurality of messages, the medium further comprises 

computer-executable instructions for: 

marking an index data to indicate whether a message in the communication client 
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is spam; 

purging all messages marked as spam prior to the step of periodically saving data 
items of the application for recovery. 

30. (Original) The medium according to claim 16 further comprises computer- 
executable instructions for: 

copying data from the application recovered at the designated point in time; 
returning to a current point in time; and 

pasting the copied data in the application in the current point in time. 

3 1 . (Withdrawn) In a computer system having a graphical user interface including a 
display and a user interface selection device, a method of providing and selecting from a 
menu on the display for recovering an application using a timeline -based computing 
environment, comprising the steps of: 

copying data from the application recovered at a designated point in time; 

moving the application to a current point in time; and 

pasting the copied data to the application in the current point in time. 

32. (Withdrawn) The computer system according to claim 3 1 further comprising the 
steps of: 

displaying a window graphical representation of the application with a pointer 
indicating different points in time; and 

recovering the application at a designated point in time. 

33. (Withdrawn) The computer system according to claim 32 wherein the window 
graphical representation of the application represents visual alternative application states via 
forking on a timeline. 
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